草庐IT

Android SurfaceView Canvas 用线程绘制

全部标签

java - hibernate 一个线程,直到来自不同类的另一个线程参加了一个事件

我有一个触发2个线程的应用程序,第一个启动另一个类来执行一些处理,然后启动第三个类来执行更多处理。主类中的第二个线程应该等到第三个类中的某个事件完成后再执行它的工作。如何实现?我曾尝试实现一个等待/通知以在两个线程之间共享一个锁对象,但从技术上讲这行不通,因为我发现了困难的方法。我可以在类之间共享锁吗?请注意,第3类的实例在第1类中声明,并作为参数传递给第2类。我还尝试在第三类中创建boolean值,告诉事件何时完成,然后轮询第二个线程直到该值为真。这有效但不是很理想。actionListner是否也是解决此问题的更好方法? 最佳答案

java - 多线程不比单线程快(简单循环测试)

我正在试验一些多线程结构,但不知何故,多线程似乎并不比单线程快。我将其缩小为一个非常简单的测试,其中包含一个嵌套循环(1000x1000),系统只在其中计算。下面我贴出了单线程和多线程的代码以及它们是如何执行的。结果是单线程完成循环大约需要110ms,而两个线程也需要大约112ms。我不认为问题是多线程的开销。如果我只将两个Runnable中的一个提交给ThreadPoolExecutor,它的执行时间是单线程的一半,这是有道理的。但是添加第二个Runnable会使它慢10倍。两个3.00Ghz内核都在100%运行。我认为这可能是特定于pc的,因为其他人的pc在多线程上显示了双倍速度的

java - 这个线程安全的字节序列生成器有什么问题?

我需要一个字节生成器来生成从Byte.MIN_VALUE到Byte.MAX_VALUE的值。当它达到MAX_VALUE时,应该从MIN_VALUE重新开始。我已经使用AtomicInteger编写了代码(见下文);但是,如果并发访问并且使用Thread.sleep()人为地减慢代码(如果没有hibernate,它运行良好;但是,我怀疑它对于并发问题的出现来说太快了),代码似乎不会正常运行。代码(添加了一些调试代码):publicclassByteGenerator{privatestaticfinalintINITIAL_VALUE=Byte.MIN_VALUE-1;privateAt

java - 为什么 Servlet 中的实例变量不是线程安全的

这个问题在这里已经有了答案:Howdoservletswork?Instantiation,sessions,sharedvariablesandmultithreading(8个答案)关闭6年前。当我阅读HeadFirstServletandJSP时,他们说实例变量是非线程安全的。我不是很理解这个说法。例如:我有一个名为ActionServlet.java的servlet。每次,每个用户的请求被发送到服务器,容器将创建一个新线程并创建新的ActionServlet实例。ActionServlet可能有一个结构:publicclassActionServletextendsHttpSe

java - 绘制一个不会在下次绘制中消失的矩形

我试图创建一个绘制矩形的JPanel。面板需要绘制很多矩形,但它们不会移动。我的问题的一个解决方案是创建一个列表,其中包含我已经创建的所有矩形,并在每次调用“Paint”时将它们全部绘制出来。但是有很多矩形,它会减慢计算机的速度。我还尝试使用repaint(x,y,height,width)来重绘新矩形的空间,但它没有用。(JPanel不断删除以前的矩形。)在某种程度上,我需要绘制不会消失所有油漆的矩形。或者一种不会删除以前绘制或不会绘制背景的绘制方法。这是我的JPanel类的一部分:classMyPanelextendsJPanel{privateintx,y,size;privat

java - 用于查看 Java 进程中的线程的实用程序

我在Windows机器上有一个Java应用程序,它时不时地固定CPU。想运行一个实用程序来了解该应用程序正在创建多少线程等。有这样的工具吗? 最佳答案 jconsole包含在jdk中,包含线程/内存/cpu监控 关于java-用于查看Java进程中的线程的实用程序,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1110664/

java - 在多线程环境下使用 HashMap

我正在做一个面试题onJavaRevisited我很难理解这个问题:What’swrongwithusingaHashMapinamultithreadedenvironment?Whenget()methodgointoaninfiniteloop?在我看来,使用HashMap不是问题在多线程环境中,只要我们的应用程序没有访问/读取正在修改创建的HashMap的线程,而不是简单地访问HashMap。因此,在我看来,只要在应用程序中我们只是访问HashMap就没有问题。在多线程环境中。请让我知道我的理解是否正确。 最佳答案 What

java - 非托管线程 Spring Quartz Websphere Hibernate

看来我们使用Quartz-JDBCJobStore以及Spring、Hibernate和Websphere的实现正在抛出非托管线程。我读了一些书,发现了一篇来自IBM的技术文章,指出将Quartz与Spring一起使用会导致这种情况。他们建议使用CommnonJ来解决这个问题。我做了一些进一步的研究,到目前为止我看到的唯一例子都是处理不在数据库中的计划旧JobStore。所以,我想知道是否有人有解决此问题的示例。谢谢 最佳答案 我们有一个可行的解决方案(实际上有两个)。1)更改quartz源代码以将WorkManager守护线程用作

java - 在多线程(Java 或 .Net)程序中,我可以假设复制变量是原子的吗?

当我想知道这个问题时,我正在担心我正在设计的应用程序中的竞争条件。假设我有一个大型数组或某种集合,由我的程序的一个组件管理,我们称该组件为Monitor。它的工作是定期检查集合是否“脏”,即。e.最近发生了变化,如果是这样,将快照写入磁盘(这是为了在发生崩溃时检查应用程序)并再次将其标记为干净。同一程序的其他组件,运行在不同的线程中,调用监视器的方法向数组/集合中添加数据或修改数据。这些方法将集合标记为脏。现在,更改方法在其他组件的线程中运行,对吧?如果我不那么幸运,它们可能会在快照写入磁盘时被调用,更改已经写入的数据,设置脏标志,然后监视器的线程将其取消设置,而不会保存更改(它改变时

Java:线程技术和概念

在使用线程时,我有时会将它们想象成将空间上下文中的对象之间的3维或更多维互连编织在一起。这不是一般用例场景,但对于我所做的事情来说,这是一种有用的思考方式。您是否使用了任何有助于线程化的API?您是否以不将线程概念化为进程的方式使用线程? 最佳答案 您是否使用任何有助于线程化的API?你是说java.util.concurrent的应用程序?FunctionalJava获得了一些有助于并发编程的构造,如开始here的多部分教程中所述.您是否以未将线程概念化为进程的方式使用线程?是的,线程根本没有概念化。以异步任务运行器为例。它在幕后